//给定一个未经排序的整数数组，找到最长且 连续递增的子序列，并返回该序列的长度。 
//
// 连续递增的子序列 可以由两个下标 l 和 r（l < r）确定，如果对于每个 l <= i < r，都有 nums[i] < nums[i + 1] ，那
//么子序列 [nums[l], nums[l + 1], ..., nums[r - 1], nums[r]] 就是连续递增子序列。 
//
// 
//
// 示例 1： 
//
// 
//输入：nums = [1,3,5,4,7]
//输出：3
//解释：最长连续递增序列是 [1,3,5], 长度为3。
//尽管 [1,3,5,7] 也是升序的子序列, 但它不是连续的，因为 5 和 7 在原数组里被 4 隔开。 
// 
//
// 示例 2： 
//
// 
//输入：nums = [2,2,2,2,2]
//输出：1
//解释：最长连续递增序列是 [2], 长度为1。
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 10⁴ 
// -10⁹ <= nums[i] <= 10⁹ 
// 
//
// Related Topics 数组 👍 470 👎 0

package leetcode.editor.cn;

import java.util.Arrays;

//java:最长连续递增序列
public class Q0674LongestContinuousIncreasingSubsequence {
    public static void main(String[] args){
        Solution solution = new Q0674LongestContinuousIncreasingSubsequence().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int findLengthOfLCIS(int[] nums) {
//        if (nums == null || nums.length == 0) {
//            return 0;
//        }
//        /*
//            1. 贪心
//         */
//        int res = 1, count = 1;
//        for (int i = 1; i < nums.length; i++) {
//            if (nums[i] > nums[i - 1]) {
//                count++;
//            } else {
//                count = 1;
//            }
//            res = Math.max(res, count);
//        }
//        return res;
        /*
            2. dp
         */
        int n = nums.length;
        // dp[i] 表示i结尾的最大连续子数列长度
        int[] dp = new int[n];
        int res = 1;
        dp[0] = 1;
        for (int i = 1; i < n; i++) {
            if (nums[i] > nums[i - 1]) {
                dp[i] = dp[i - 1] + 1;
            } else {
                dp[i] = 1;
            }
            if (dp[i] > res) {
                res = dp[i];
            }
        }
        // 效率低
        return res;
//        return Arrays.stream(dp).max().orElse(1);
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}